APIs এবং RESTful Services (এপিআই এবং রেস্টফুল সার্ভিসেস)

Computer Programming - নোড জেএস (Node.js)
208

API (Application Programming Interface) এবং RESTful Services হল ওয়েব অ্যাপ্লিকেশন ডেভেলপমেন্টের গুরুত্বপূর্ণ অংশ, যা সিস্টেম বা অ্যাপ্লিকেশনের মধ্যে ডেটা শেয়ার এবং ইন্টারঅ্যাকশন করতে সহায়তা করে। API হল এমন একটি ইন্টারফেস যা দুটি অ্যাপ্লিকেশন বা সিস্টেমের মধ্যে যোগাযোগ স্থাপন করতে ব্যবহৃত হয়, এবং RESTful Services হল এমন একটি স্টাইল যা ওয়েব সার্ভিসের মাধ্যমে অ্যাপ্লিকেশনগুলি একে অপরের সাথে যোগাযোগ করে।


১. API (Application Programming Interface)

API (অ্যাপ্লিকেশন প্রোগ্রামিং ইন্টারফেস) হলো একটি সেট নিয়ম এবং প্রটোকল যা দুটি সফটওয়্যার সিস্টেমের মধ্যে ইন্টারঅ্যাকশন করতে সহায়তা করে। এটি সাধারণত ফাংশন, মেথড বা প্রটোকল হিসেবে একটি সিস্টেমের বৈশিষ্ট্য বা ডেটা অন্য একটি সিস্টেমে ব্যবহারের জন্য প্রকাশ করে। API বিভিন্ন ধরণের হতে পারে, যেমন:

  • REST API
  • SOAP API
  • GraphQL API

এপিআই ব্যবহার করে এক অ্যাপ্লিকেশন অন্য অ্যাপ্লিকেশন বা সার্ভিসের সঙ্গে যোগাযোগ করতে পারে এবং ডেটা বা কার্যক্রম শেয়ার করতে পারে। উদাহরণস্বরূপ, Twitter API ব্যবহার করে আপনি Twitter থেকে ডেটা সংগ্রহ করতে পারেন, এবং Google Maps API ব্যবহার করে ম্যাপ ডেটা প্রাপ্তি করতে পারেন।

API এর সুবিধা:

  • ডেটা শেয়ারিং: বিভিন্ন অ্যাপ্লিকেশন বা সিস্টেমের মধ্যে সহজে ডেটা শেয়ার করা যায়।
  • কাস্টম ফিচার: কোনো সিস্টেমে থাকা ফিচার বা কার্যক্রম অন্য সিস্টেমে ব্যবহার করা সম্ভব।
  • স্কেলেবিলিটি: বড় অ্যাপ্লিকেশন গুলি একে অপরের সাথে API মাধ্যমে ইন্টিগ্রেট করা যেতে পারে।

২. RESTful Services (RESTful সার্ভিসেস)

REST (Representational State Transfer) একটি আর্কিটেকচারাল স্টাইল যা HTTP প্রোটোকল ব্যবহার করে সার্ভিসের মধ্যে ডেটা ট্রান্সফার করতে ব্যবহৃত হয়। RESTful সার্ভিসগুলি সাধারণত HTTP মেথড (GET, POST, PUT, DELETE) ব্যবহার করে ডেটা পরিচালনা এবং রিকোয়েস্ট হ্যান্ডলিংয়ের জন্য ওয়েব সার্ভিস সরবরাহ করে।

RESTful API এর মূল নীতিমালা:

  1. Stateless: প্রতিটি HTTP রিকোয়েস্টে সব প্রয়োজনীয় তথ্য (যেমন, অথেনটিকেশন) থাকতে হবে। সার্ভার সেশনের অবস্থা রাখে না, অর্থাৎ প্রতিটি রিকোয়েস্ট এককভাবে সম্পাদিত হয়।
  2. Client-Server Architecture: ক্লায়েন্ট এবং সার্ভারের মধ্যে স্পষ্টভাবে বিভক্তি রয়েছে। ক্লায়েন্ট শুধুমাত্র রিকোয়েস্ট পাঠায়, এবং সার্ভার সেগুলোর প্রক্রিয়া করে রেসপন্স পাঠায়।
  3. Cacheable: রেসপন্সে ক্যাশিংয়ের বৈশিষ্ট্য থাকতে পারে, যার ফলে কার্যক্ষমতা বাড়ে এবং সার্ভার লোড কমে।
  4. Uniform Interface: RESTful API এ রিকোয়েস্ট এবং রেসপন্সের একটি স্পষ্ট, স্ট্যান্ডার্ড ফরম্যাট থাকে।

HTTP মেথডস এবং RESTful API:

  • GET: ডেটা রিট্রিভ করতে ব্যবহৃত হয়।
  • POST: নতুন ডেটা তৈরি করতে ব্যবহৃত হয়।
  • PUT: বিদ্যমান ডেটা আপডেট করতে ব্যবহৃত হয়।
  • DELETE: ডেটা ডিলিট করতে ব্যবহৃত হয়।

উদাহরণ:

ধরা যাক, আপনার একটি User রিসোর্স আছে এবং আপনি RESTful API ব্যবহার করে এটি পরিচালনা করছেন। নিচে কিছু উদাহরণ দেওয়া হলো:

  • GET /users: সকল ব্যবহারকারীর তথ্য প্রাপ্তি।
  • GET /users/{id}: নির্দিষ্ট ID এর ব্যবহারকারীর তথ্য প্রাপ্তি।
  • POST /users: নতুন ব্যবহারকারী তৈরি করা।
  • PUT /users/{id}: নির্দিষ্ট ID এর ব্যবহারকারীর তথ্য আপডেট করা।
  • DELETE /users/{id}: নির্দিষ্ট ID এর ব্যবহারকারী ডিলিট করা।

৩. Express.js এর মাধ্যমে RESTful API তৈরি করা

Express.js একটি জনপ্রিয় Node.js ফ্রেমওয়ার্ক যা দ্রুত RESTful API তৈরি করতে সাহায্য করে। নিচে একটি সাধারণ RESTful API তৈরি করার উদাহরণ দেওয়া হলো।

স্টেপ ১: Express.js ইনস্টলেশন

প্রথমে Express ইনস্টল করতে হবে:

npm install express --save

স্টেপ ২: RESTful API তৈরি করা

const express = require('express');
const app = express();
app.use(express.json());  // JSON বডি পার্সিং

// একটি সিম্পল ইন-মেমরি ডেটাবেস (একটি অ্যারে)
const users = [
  { id: 1, name: 'John Doe', age: 30 },
  { id: 2, name: 'Jane Doe', age: 25 }
];

// GET /users - সকল ব্যবহারকারীর তথ্য প্রাপ্তি
app.get('/users', (req, res) => {
  res.json(users);
});

// GET /users/:id - নির্দিষ্ট ID এর ব্যবহারকারী প্রাপ্তি
app.get('/users/:id', (req, res) => {
  const user = users.find(u => u.id === parseInt(req.params.id));
  if (!user) return res.status(404).send('User not found');
  res.json(user);
});

// POST /users - নতুন ব্যবহারকারী তৈরি
app.post('/users', (req, res) => {
  const newUser = {
    id: users.length + 1,
    name: req.body.name,
    age: req.body.age
  };
  users.push(newUser);
  res.status(201).json(newUser);
});

// PUT /users/:id - ব্যবহারকারী আপডেট
app.put('/users/:id', (req, res) => {
  const user = users.find(u => u.id === parseInt(req.params.id));
  if (!user) return res.status(404).send('User not found');
  
  user.name = req.body.name;
  user.age = req.body.age;
  res.json(user);
});

// DELETE /users/:id - ব্যবহারকারী ডিলিট
app.delete('/users/:id', (req, res) => {
  const userIndex = users.findIndex(u => u.id === parseInt(req.params.id));
  if (userIndex === -1) return res.status(404).send('User not found');
  
  const deletedUser = users.splice(userIndex, 1);
  res.json(deletedUser);
});

// সার্ভার চালু করা
app.listen(3000, () => {
  console.log('Server running at http://localhost:3000/');
});

এখানে:

  • GET /users: সকল ব্যবহারকারীর তথ্য প্রদান করবে।
  • GET /users/:id: নির্দিষ্ট ID এর ব্যবহারকারীর তথ্য প্রদান করবে।
  • POST /users: নতুন ব্যবহারকারী তৈরি করবে।
  • PUT /users/:id: নির্দিষ্ট ID এর ব্যবহারকারী আপডেট করবে।
  • DELETE /users/:id: নির্দিষ্ট ID এর ব্যবহারকারী ডিলিট করবে।

৪. API Security (এপিআই সিকিউরিটি)

API তৈরি করার সময় Security বিষয়টি গুরুত্বপূর্ণ। কিছু সাধারণ সিকিউরিটি প্র্যাকটিস:

  1. API Key Authentication: API রিকোয়েস্টে একটি সিক্রেট কী প্রেরণ করা হয়, যার মাধ্যমে অ্যাক্সেস কন্ট্রোল করা যায়।
  2. JWT (JSON Web Tokens): ক্লায়েন্ট সার্ভারের মধ্যে নিরাপদে ডেটা ট্রান্সফার করার জন্য ব্যবহৃত হয়। এটি সাইন ইন এবং অথেনটিকেশন প্রক্রিয়াকে সহজ এবং নিরাপদ করে তোলে।
  3. OAuth: এক্সটার্নাল সার্ভিসের মাধ্যমে অথেনটিকেশন এবং অথরাইজেশন পরিচালনা করতে ব্যবহৃত হয়, যেমন গুগল বা ফেসবুকের মাধ্যমে লগইন।

সারাংশ

  • API হল এমন একটি ইন্টারফেস যা দুটি সিস্টেমের মধ্যে যোগাযোগ স্থাপন করে। RESTful API ওয়েব অ্যাপ্লিকেশনের জন্য জনপ্রিয় এবং এটি HTTP মেথড (GET, POST, PUT, DELETE) ব্যবহার করে ডেটা পরিচালনা করে।
  • Express.js ব্যবহার করে সহজে RESTful API তৈরি করা সম্ভব এবং এটি দ্রুত ওয়েব সার্ভিস তৈরি করতে সহায়তা করে।
  • Authentication এবং Authorization সহ API সিকিউরিটি বিষয়গুলো খুবই গুরুত্বপূর্ণ এবং এটি অ্যাপ্লিকেশনের নিরাপত্তা নিশ্চিত করে।

RESTful API এবং Express.js দিয়ে আপনি সহজেই কার্যকরী ওয়েব অ্যাপ্লিকেশন তৈরি করতে পারবেন, যেখানে আপনি ডেটা পরিচালনা, প্রক্রিয়া, এবং নিরাপত্তা নিশ্চিত করতে পারবেন।

Content added By

REST API এর ধারণা এবং প্রয়োজনীয়তা

190

REST API (Representational State Transfer API) হল একটি ওয়েব সেবা প্রোগ্রামিং ইন্টারফেস যা HTTP প্রটোকল ব্যবহার করে ক্লায়েন্ট এবং সার্ভারের মধ্যে ডেটা আদান-প্রদান করতে সহায়তা করে। এটি বিশেষভাবে ওয়েব অ্যাপ্লিকেশন এবং মোবাইল অ্যাপ্লিকেশন ডেভেলপমেন্টে ব্যবহৃত হয়। REST এর ধারণাটি HTTP/HTTPS প্রোটোকলের উপর ভিত্তি করে কাজ করে এবং এটি একটি নির্দিষ্ট স্টাইল অনুসরণ করে যা একাধিক ডিভাইসের মধ্যে সহজে যোগাযোগ করতে সক্ষম।

REST API গুলি সাধারণত HTTP মেথডস (GET, POST, PUT, DELETE, PATCH) ব্যবহার করে ডেটা পরিচালনা করে। RESTful API একটি সহজ, স্কেলেবল এবং লাইটওয়েট ওয়েব সেবা প্রদান করে যা কম্প্লেক্স অপারেশন সহজে সম্পাদন করতে সক্ষম।


১. REST API এর মৌলিক ধারণা

REST হল একটি আর্কিটেকচারাল স্টাইল, যা ক্লায়েন্ট এবং সার্ভারের মধ্যে যোগাযোগের জন্য কিছু মৌলিক নিয়ম এবং সীমাবদ্ধতা প্রদান করে। REST এর জন্য কিছু প্রধান বৈশিষ্ট্য:

  1. Stateless:
    • প্রতিটি রিকোয়েস্ট সম্পূর্ণভাবে স্বতন্ত্র। সার্ভার ইউজারের পূর্ববর্তী রিকোয়েস্ট সম্পর্কে কোন তথ্য সংরক্ষণ করে না। অর্থাৎ, প্রতিটি রিকোয়েস্টের জন্য সার্ভার কোনও স্টেট (অবস্থা) সংরক্ষণ করতে হয় না।
  2. Client-Server Architecture:
    • REST একটি ক্লায়েন্ট-সার্ভার আর্কিটেকচার অনুসরণ করে, যেখানে ক্লায়েন্ট এবং সার্ভার আলাদা থাকে এবং HTTP প্রোটোকল মাধ্যমে একে অপরের সাথে যোগাযোগ করে। সার্ভার ডেটা সরবরাহ করে, আর ক্লায়েন্ট ইউজারের ইন্টারফেস প্রদর্শন করে।
  3. Uniform Interface:
    • RESTful API এর একটি স্ট্যান্ডার্ড ইন্টারফেস থাকে, যা HTTP প্রটোকলের উপর ভিত্তি করে থাকে এবং সাধারিতভাবে URI (Uniform Resource Identifier) ব্যবহার করে।
  4. Cacheable:
    • REST API রেসপন্সে ক্যাশিং সমর্থন করে, যার মানে হল যে ক্লায়েন্টের রিকোয়েস্টের ফলাফলকে ক্যাশে রাখা যেতে পারে যাতে পরবর্তী রিকোয়েস্টে দ্রুত ফলাফল পাওয়া যায়।
  5. Layered System:
    • RESTful সিস্টেমে সার্ভারের মধ্যে একাধিক লেয়ার থাকতে পারে। এটি লোড ব্যালেন্সিং এবং নিরাপত্তা সিস্টেমের জন্য ব্যবহৃত হয়।
  6. Code on Demand (optional):
    • REST API কিছু কোড প্রদান করতে পারে যা ক্লায়েন্ট সাইডে রান করতে পারে (যেমন JavaScript), তবে এটি ঐচ্ছিক।

২. REST API এর মেথডস

RESTful API বিভিন্ন HTTP মেথড ব্যবহার করে বিভিন্ন ধরণের অপারেশন সম্পাদন করে। এই মেথডগুলো হল:

  1. GET:
    • ডেটা পাওয়ার জন্য ব্যবহার করা হয়। GET মেথড ব্যবহার করে সার্ভার থেকে ডেটা রিট্রিভ করা হয়।
    • উদাহরণ: GET /users - সব ইউজারের ডেটা প্রাপ্তি।
  2. POST:
    • নতুন ডেটা তৈরি করার জন্য ব্যবহার করা হয়। POST মেথড নতুন রিসোর্স সার্ভারে পাঠানোর জন্য ব্যবহৃত হয়।
    • উদাহরণ: POST /users - নতুন ইউজার তৈরি করা।
  3. PUT:
    • একটি সম্পূর্ণ রিসোর্স আপডেট করার জন্য ব্যবহৃত হয়। PUT মেথড ব্যবহার করে আপনি একটি সম্পূর্ণ ডেটা আপডেট করতে পারেন।
    • উদাহরণ: PUT /users/1 - ইউজারের তথ্য সম্পূর্ণভাবে আপডেট করা।
  4. PATCH:
    • একটি রিসোর্সের অংশিক আপডেট করার জন্য ব্যবহৃত হয়।
    • উদাহরণ: PATCH /users/1 - ইউজারের কিছু তথ্য আপডেট করা।
  5. DELETE:
    • একটি রিসোর্স মুছে ফেলতে ব্যবহৃত হয়। DELETE মেথড একটি নির্দিষ্ট রিসোর্স সার্ভার থেকে মুছে ফেলে।
    • উদাহরণ: DELETE /users/1 - ইউজার ডিলিট করা।

৩. REST API এর প্রয়োজনীয়তা

REST API আজকের দিনে ওয়েব এবং মোবাইল অ্যাপ্লিকেশন ডেভেলপমেন্টে অত্যন্ত গুরুত্বপূর্ণ। এর কিছু গুরুত্বপূর্ণ প্রয়োজনীয়তা এবং সুবিধা:

a. কমপ্লেক্সিটির কমানো:

  • REST API সহজ ও সুসংগঠিত কাঠামো প্রদান করে। এটি ডেটার জন্য একটি সাধারণ প্রবাহ প্রদান করে যা ডেভেলপারদের কাজকে আরও সহজ করে।

b. প্ল্যাটফর্ম-নিরপেক্ষ:

  • RESTful API যেকোনো প্ল্যাটফর্মের সাথে কাজ করতে পারে। এটি বিভিন্ন ডিভাইস যেমন ওয়েব, মোবাইল অ্যাপ্লিকেশন, IoT ডিভাইস ইত্যাদির সাথে ইন্টিগ্রেট করা যেতে পারে।

c. স্কেলেবল:

  • REST API অত্যন্ত স্কেলেবল, কারণ এটি stateless, অর্থাৎ সার্ভার কোনো স্টেট সংরক্ষণ করে না। এটি অ্যাপ্লিকেশনটিকে আরো লোড ব্যালেন্সিং এবং উচ্চ ট্রাফিক পরিচালনা করতে সক্ষম করে।

d. ডেটা নির্ভরযোগ্যতা:

  • RESTful API সিস্টেমে ডেটার জন্য সহজ এবং নিরাপদ যোগাযোগ হয়, যেটি রিয়েল-টাইম ডেটা আদান-প্রদানকে নিশ্চিত করে।

e. ব্রাউজার এবং মোবাইল ইন্টিগ্রেশন:

  • REST API ওয়েব ব্রাউজার, মোবাইল অ্যাপ্লিকেশন এবং অন্যান্য ডিভাইসের সাথে সহজেই ইন্টিগ্রেট করা যায়, কারণ এটি HTTP প্রটোকলের উপর ভিত্তি করে কাজ করে।

f. ক্যাশিং সুবিধা:

  • RESTful API রেসপন্স ক্যাশ করা যেতে পারে, যার ফলে পরবর্তী রিকোয়েস্টগুলির জন্য দ্রুত ফলাফল প্রদান করা হয়।

g. বহু ক্লায়েন্ট সাপোর্ট:

  • একাধিক ক্লায়েন্ট যেমন ওয়েব, মোবাইল, এবং ডেক্সটপ অ্যাপ্লিকেশন থেকে একসাথে একটি REST API ব্যবহৃত হতে পারে। এটি খুবই নমনীয় এবং সহজে স্কেল করা যায়।

৪. REST API এর উদাহরণ

a. GET রিকোয়েস্ট উদাহরণ

GET /users

এটি সার্ভার থেকে সমস্ত ইউজারের ডেটা পাঠাবে।

b. POST রিকোয়েস্ট উদাহরণ

POST /users
{
  "name": "John",
  "email": "john@example.com"
}

এটি একটি নতুন ইউজার তৈরি করবে।

c. PUT রিকোয়েস্ট উদাহরণ

PUT /users/1
{
  "name": "John Doe",
  "email": "john.doe@example.com"
}

এটি ইউজারের তথ্য সম্পূর্ণভাবে আপডেট করবে।

d. DELETE রিকোয়েস্ট উদাহরণ

DELETE /users/1

এটি ইউজারটি ডিলিট করবে।


সারাংশ

REST API হল একটি শক্তিশালী এবং জনপ্রিয় ওয়েব সেবা ইন্টারফেস যা HTTP/HTTPS প্রোটোকল ব্যবহার করে ক্লায়েন্ট এবং সার্ভারের মধ্যে যোগাযোগ করে। এটি ওয়েব ও মোবাইল অ্যাপ্লিকেশন ডেভেলপমেন্টে ব্যবহৃত হয় এবং সহজ, স্কেলেবল, এবং দ্রুত ডেটা আদান-প্রদান সিস্টেম প্রদান করে। RESTful API একটি স্ট্যাটলেস, প্ল্যাটফর্ম-নিরপেক্ষ, এবং নিরাপদ সিস্টেম প্রদান করে, যা রিয়েল-টাইম ডেটা অ্যাডভান্সড অ্যাপ্লিকেশন ডেভেলপমেন্টের জন্য অপরিহার্য।

Content added By

HTTP Methods: GET, POST, PUT, DELETE

421

HTTP Methods হল ক্লায়েন্ট এবং সার্ভারের মধ্যে যোগাযোগের বিভিন্ন ধরনের রিকোয়েস্ট নির্দেশ করার উপায়। প্রতিটি HTTP মেথডের একটি নির্দিষ্ট উদ্দেশ্য এবং ব্যবহার রয়েছে। এখানে আমরা চারটি প্রধান HTTP মেথড — GET, POST, PUT, এবং DELETE এর সম্পর্কে আলোচনা করব।


১. GET Method

GET মেথডটি সার্ভার থেকে তথ্য পড়তে ব্যবহৃত হয়। এটি সাধারণত ডেটা রিকোয়েস্ট করার জন্য ব্যবহৃত হয় এবং ইউজাররা সাধারণত URL এর মাধ্যমে GET রিকোয়েস্ট পাঠায় (যেমন ব্রাউজারের অ্যাড্রেস বারে)। GET রিকোয়েস্টে সাধারণত কোনও বডি থাকে না, শুধুমাত্র URL এবং কুয়েরি প্যারামিটার থাকে।

ব্যবহার:

  • ডেটা রিড করার জন্য (যেমন, ডাটাবেস থেকে তথ্য নিয়ে আসা)।
  • কমপ্লেক্স রিকোয়েস্টের জন্য নয় (GET রিকোয়েস্ট মূলত শুধুমাত্র তথ্য পড়ার জন্য).

উদাহরণ:

app.get('/users', (req, res) => {
  res.send('Fetching users...');
});

এখানে, /users রুটে GET রিকোয়েস্ট আসলে এটি ইউজারদের তথ্য নিয়ে আসবে।


২. POST Method

POST মেথডটি সার্ভারে নতুন তথ্য বা নতুন রেকর্ড পাঠাতে ব্যবহৃত হয়। সাধারণত যখন ইউজার ফর্ম সাবমিট করে অথবা নতুন ডেটা তৈরি করতে চায়, তখন POST রিকোয়েস্ট পাঠানো হয়। POST রিকোয়েস্টে বডি থাকে, যেখানে ইউজারের ইনপুট ডেটা পাঠানো হয়।

ব্যবহার:

  • নতুন রেকর্ড তৈরি (যেমন ডাটাবেসে নতুন ইউজার তৈরি করা)।
  • অন্যান্য তথ্য সাবমিট করা (যেমন লগইন তথ্য পাঠানো)।

উদাহরণ:

app.post('/users', (req, res) => {
  const newUser = req.body;
  res.send(`User ${newUser.name} created!`);
});

এখানে, /users রুটে POST রিকোয়েস্টে নতুন ইউজার তৈরি করা হচ্ছে, এবং req.body থেকে ইউজারের ইনপুট নেওয়া হচ্ছে।


৩. PUT Method

PUT মেথডটি সার্ভারের আগের ডেটা আপডেট করতে ব্যবহৃত হয়। PUT রিকোয়েস্টে, আপনি যে রিসোর্স (ডেটা) আপডেট করতে চান তার জন্য ডেটা পাঠান। এটি সাধারণত পুরনো ডেটা সম্পূর্ণরূপে প্রতিস্থাপন করার জন্য ব্যবহৃত হয়, যেটি নতুন ডেটা দিয়ে আপডেট করা হয়।

ব্যবহার:

  • রেকর্ড আপডেট করা (যেমন, ইউজারের প্রোফাইল তথ্য আপডেট করা)।
  • পূর্ণ ডেটা প্রতিস্থাপন করা।

উদাহরণ:

app.put('/users/:id', (req, res) => {
  const userId = req.params.id;
  const updatedUser = req.body;
  res.send(`User with ID ${userId} updated!`);
});

এখানে, /users/:id রুটে PUT রিকোয়েস্টে ডেটা আপডেট করা হচ্ছে। req.params.id দিয়ে ইউজারের আইডি নেওয়া হচ্ছে এবং req.body দিয়ে আপডেট হওয়া ডেটা পাঠানো হচ্ছে।


৪. DELETE Method

DELETE মেথডটি সার্ভার থেকে তথ্য মুছতে ব্যবহৃত হয়। DELETE রিকোয়েস্টে, আপনি সার্ভারের একটি রিসোর্স (যেমন ডাটাবেস রেকর্ড) মুছে ফেলতে চান। এটি ডেটা সম্পূর্ণভাবে মুছে ফেলার জন্য ব্যবহৃত হয় এবং বডি সাধারণত থাকে না (যেহেতু এটি শুধুমাত্র ডেটা মুছে ফেলার জন্য ব্যবহৃত)।

ব্যবহার:

  • রেকর্ড মুছতে (যেমন, ইউজারের প্রোফাইল মুছে ফেলা)।

উদাহরণ:

app.delete('/users/:id', (req, res) => {
  const userId = req.params.id;
  res.send(`User with ID ${userId} deleted!`);
});

এখানে, /users/:id রুটে DELETE রিকোয়েস্টে একটি ইউজার ডিলিট করা হচ্ছে। req.params.id দিয়ে ইউজারের আইডি নেওয়া হচ্ছে।


সারাংশ

HTTP MethodPurposeUse Case Example
GETডেটা পড়া (retrieve data)ফাইল বা ডাটাবেস থেকে তথ্য পড়া, ইউজার প্রোফাইল দেখানো
POSTনতুন ডেটা পাঠানো (send new data)ফর্ম সাবমিট, নতুন রেকর্ড তৈরি করা, লগইন তথ্য পাঠানো
PUTপুরনো ডেটা আপডেট করা (update data)ইউজারের প্রোফাইল আপডেট করা, তথ্য সংশোধন করা
DELETEডেটা মুছে ফেলা (delete data)ডাটাবেস থেকে একটি রেকর্ড মুছা, ইউজার ডিলিট করা

এভাবে, GET, POST, PUT, এবং DELETE HTTP মেথডগুলি ওয়েব অ্যাপ্লিকেশন তৈরি করার সময় বিভিন্ন ধরনের অপারেশন যেমন ডেটা রিড, রাইট, আপডেট এবং ডিলিট করার জন্য ব্যবহৃত হয়। Express.js এর মাধ্যমে এই মেথডগুলো খুব সহজে ব্যবহার করা সম্ভব।

Content added By

API Routes এবং Parameters

209

API Routes এবং Parameters হল ওয়েব অ্যাপ্লিকেশন ডেভেলপমেন্টে গুরুত্বপূর্ণ উপাদান। API Routes হল URL পাথ যেখানে ওয়েব সার্ভিসের মাধ্যমে ডাটা আদান-প্রদান করা হয়, এবং Parameters হল সেই URL পাথের অংশ যেগুলি ডাইনামিক ডাটা (যেমন আইডি, কুয়েরি প্যারামিটার) ধারণ করে যা API এর কার্যকলাপকে প্রভাবিত করে।

Node.js এবং Express ব্যবহার করে API Routes তৈরি এবং Parameters ব্যবহার করা সহজ এবং কার্যকরী।


১. API Routes

API Routes হল URL পাথ যেখানে HTTP রিকোয়েস্ট (GET, POST, PUT, DELETE) পাঠানোর মাধ্যমে ডাটা প্রসেস বা পরিচালনা করা হয়। Express ব্যবহার করে API Routes তৈরি করা হয়। API রাউটের মাধ্যমে ডেটা একটি নির্দিষ্ট URL পাথে পাঠানো বা গ্রহণ করা যায়, যা ডাইনামিকভাবে ইউজারের রিকোয়েস্টের উপর ভিত্তি করে প্রক্রিয়াকৃত হয়।

Express এ API Routes তৈরি করা

  1. GET রিকোয়েস্ট: ডাটাবেস বা অন্য কোনও ডাটা সোর্স থেকে ডাটা পড়তে।
  2. POST রিকোয়েস্ট: ডাটা তৈরি বা আপলোড করতে।
  3. PUT রিকোয়েস্ট: বিদ্যমান ডাটাকে আপডেট করতে।
  4. DELETE রিকোয়েস্ট: ডাটা মুছে ফেলতে।
const express = require('express');
const app = express();

// JSON পার্স করার জন্য middleware
app.use(express.json());

// GET রিকোয়েস্টের মাধ্যমে ডাটা পড়া
app.get('/api/users', (req, res) => {
  res.json([{ name: 'John Doe', age: 30 }, { name: 'Jane Doe', age: 25 }]);
});

// POST রিকোয়েস্টের মাধ্যমে ডাটা তৈরি করা
app.post('/api/users', (req, res) => {
  const newUser = req.body;
  // নতুন ইউজারকে ডাটাবেসে সংরক্ষণ করা হবে (এখানে শুধু ডাটা ফিরিয়ে দিচ্ছি)
  res.status(201).json(newUser);  // 201 - Created
});

// PUT রিকোয়েস্টের মাধ্যমে ডাটা আপডেট করা
app.put('/api/users/:id', (req, res) => {
  const userId = req.params.id;  // URL প্যারামিটার থেকে আইডি নেওয়া
  const updatedUser = req.body;
  res.json({ id: userId, ...updatedUser });  // আপডেট করা ডাটা ফিরিয়ে দেওয়া
});

// DELETE রিকোয়েস্টের মাধ্যমে ডাটা মুছে ফেলা
app.delete('/api/users/:id', (req, res) => {
  const userId = req.params.id;
  res.status(200).send(`User with id ${userId} deleted`);  // সফলভাবে ইউজার ডিলিটের বার্তা
});

// সার্ভার চালু করা
app.listen(3000, () => {
  console.log('Server running at http://localhost:3000');
});

এখানে, /api/users রাউটটি GET, POST, PUT, এবং DELETE রিকোয়েস্ট হ্যান্ডল করছে।


২. Parameters (প্যারামিটারস)

Parameters হল ডাটা যা URL পাথ বা রিকোয়েস্টের সাথে যুক্ত থাকে। Express এ মূলত তিন ধরনের প্যারামিটার ব্যবহৃত হয়:

  1. Route Parameters (Path Parameters)
  2. Query Parameters
  3. Body Parameters

১. Route Parameters (Path Parameters)

এগুলি URL পাথের অংশ হিসাবে ব্যবহৃত হয় এবং ডাইনামিকভাবে URL এর মধ্যে পাস করা হয়। এগুলি কলব্যাক ফাংশনের মাধ্যমে req.params এ অ্যাক্সেস করা যায়।

উদাহরণ:
// URL প্যারামিটার দিয়ে রাউট তৈরি করা
app.get('/api/users/:id', (req, res) => {
  const userId = req.params.id;  // `id` প্যারামিটারটি URL থেকে নেওয়া হচ্ছে
  res.send(`User ID is ${userId}`);
});

এখানে, /api/users/:id রাউটটি একটি ডাইনামিক id প্যারামিটার গ্রহণ করে, যা ইউজারের ID হিসেবে ব্যবহার করা হচ্ছে।

২. Query Parameters

Query Parameters URL এর শেষে ? চিহ্নের পরে কীবোর্ড প্যারামিটার হিসেবে পাঠানো হয় এবং এটি req.query অবজেক্টের মাধ্যমে অ্যাক্সেস করা যায়। সাধারণত, কুয়েরি প্যারামিটার ফিল্টারিং বা সার্চের জন্য ব্যবহৃত হয়।

উদাহরণ:
// কুয়েরি প্যারামিটার দিয়ে রাউট তৈরি করা
app.get('/api/users', (req, res) => {
  const { name, age } = req.query;  // কুয়েরি প্যারামিটার থেকে ডাটা নেওয়া
  res.send(`Search users with name: ${name} and age: ${age}`);
});

এখানে, /api/users?name=John&age=30 এই URL দিয়ে ইউজারের নাম এবং বয়স অনুসারে ডাটা ফেরত আসবে।

৩. Body Parameters

Body Parameters সাধারণত POST, PUT, অথবা PATCH রিকোয়েস্টের মাধ্যমে পাঠানো হয়। এগুলি req.body এর মাধ্যমে অ্যাক্সেস করা যায়। Body প্যারামিটার সাধারণত ফর্ম ডাটা বা JSON ডাটা হিসেবে আসে।

উদাহরণ:
// POST রিকোয়েস্টের মাধ্যমে body প্যারামিটার পাঠানো
app.post('/api/users', (req, res) => {
  const newUser = req.body;  // Body থেকে ইউজারের ডাটা নেওয়া
  res.status(201).send(newUser);  // নতুন ইউজারের ডাটা ফিরিয়ে দেওয়া
});

এখানে, ক্লায়েন্ট সাইডে POST রিকোয়েস্টের মাধ্যমে JSON ডাটা পাঠানো হবে, যেমন:

{
  "name": "John",
  "age": 30
}

৩. Combination of Parameters

কখনও কখনও URL পাথ, কুয়েরি প্যারামিটার এবং বডি প্যারামিটার একসাথে ব্যবহার করা হয়। উদাহরণস্বরূপ, একটি ইউজারের ডাটা আপডেট করতে URL পাথ থেকে id প্যারামিটার এবং body থেকে নতুন ডাটা নেওয়া হতে পারে।

উদাহরণ:
app.put('/api/users/:id', (req, res) => {
  const userId = req.params.id;  // URL পাথ থেকে id প্যারামিটার
  const updatedData = req.body;  // Body থেকে আপডেট করা ডাটা

  res.send(`User with ID ${userId} updated with data: ${JSON.stringify(updatedData)}`);
});

এখানে, /api/users/:id URL পাথের মাধ্যমে একটি নির্দিষ্ট ইউজারের ID নেয় এবং তার পরবর্তী ডাটা req.body থেকে নেয়।


সারাংশ

  • API Routes হল URL পাথ যা HTTP রিকোয়েস্টের মাধ্যমে ডাটা আদান-প্রদান এবং কার্যক্রম পরিচালনা করে।
  • Parameters URL পাথ বা রিকোয়েস্টের অংশ হিসেবে ডাটা প্রদান করে এবং এটি তিন ধরনের হতে পারে:
    1. Route Parameters (Path Parameters): URL পাথের অংশ হিসেবে।
    2. Query Parameters: URL পাথের পরে ? চিহ্নের মাধ্যমে পাঠানো হয়।
    3. Body Parameters: POST, PUT, বা PATCH রিকোয়েস্টের মাধ্যমে পাঠানো হয়।
  • Express এ req.params, req.query, এবং req.body এর মাধ্যমে প্যারামিটারগুলো অ্যাক্সেস করা হয়।
Content added By

API Testing এবং Postman ব্যবহার

243

API Testing হল একটি প্রক্রিয়া যেখানে আপনি আপনার API এর কার্যকারিতা যাচাই করেন, যাতে নিশ্চিত হওয়া যায় যে এটি সঠিকভাবে কাজ করছে। API testing মূলত RESTful APIs বা GraphQL APIs তে ব্যবহৃত হয়, এবং এখানে আমরা Postman টুলটি ব্যবহার করে API Testing করার পদ্ধতি দেখাব।

Postman হল একটি জনপ্রিয় টুল যা API ডেভেলপমেন্ট, টেস্টিং এবং ডিবাগিং এর জন্য ব্যবহৃত হয়। এটি একটি ইউজার ফ্রেন্ডলি ইন্টারফেস প্রদান করে, যেখানে আপনি API রিকোয়েস্ট পাঠাতে পারেন, রেসপন্স দেখতে পারেন এবং API এর বিভিন্ন পারফরম্যান্স যাচাই করতে পারেন।

এখানে আমরা API Testing এবং Postman এর ব্যবহার সম্পর্কে বিস্তারিত আলোচনা করব।


১. API Testing Overview

API টেস্টিং এমন একটি প্রক্রিয়া যা আপনার API এর বৈশিষ্ট্য, পারফরম্যান্স, নিরাপত্তা, এবং অন্যান্য কার্যকারিতা যাচাই করতে সাহায্য করে। সাধারণ API টেস্টিং মডিউলগুলো অন্তর্ভুক্ত থাকে:

  • Functional Testing: যাচাই করা হয় যে API এর প্রত্যাশিত আউটপুট তৈরি হচ্ছে কি না।
  • Load Testing: API এর পারফরম্যান্স যাচাই করা হয় বিশেষত অনেক রিকোয়েস্ট পাঠানোর পর।
  • Security Testing: API এর নিরাপত্তা পরীক্ষা করা হয়।
  • Error Handling: API রেসপন্সে সঠিক ত্রুটি বার্তা পাচ্ছেন কিনা তা পরীক্ষা করা হয়।

API টেস্টিং করার সময় সাধারণত HTTP মেথডগুলি যেমন GET, POST, PUT, DELETE ইত্যাদি ব্যবহার করা হয়।


২. Postman ব্যবহার করে API Testing

Postman হল একটি GUI (Graphical User Interface) টুল যা API রিকোয়েস্ট পাঠাতে এবং রেসপন্স দেখতে সাহায্য করে। এটি আপনাকে রিকোয়েস্ট পাঠানোর জন্য সঠিক HTTP মেথড, URL, হেডার, প্যারামিটার এবং বডি কনফিগার করার সুবিধা দেয়।

Step 1: Postman ইনস্টল করা

Postman আপনার কম্পিউটারে ইনস্টল করা থাকতে হবে। আপনি Postman Official Website থেকে এটি ডাউনলোড করে ইনস্টল করতে পারেন।

Step 2: Postman Interface Overview

  • Request Type: এখানে আপনি HTTP মেথড (GET, POST, PUT, DELETE, ইত্যাদি) নির্বাচন করতে পারবেন।
  • URL: এখানে API এর URL অথবা endpoint ইনপুট করতে হবে।
  • Headers: API রিকোয়েস্টের জন্য প্রয়োজনীয় হেডার গুলি কনফিগার করা যায়।
  • Body: যদি রিকোয়েস্টের মধ্যে ডাটা প্রেরণ করতে হয় (যেমন POST বা PUT রিকোয়েস্ট), তাহলে এখানে ডাটা প্রদান করতে হবে।

Step 3: GET Request Testing (API Request পাঠানো)

ধরা যাক, আমাদের একটি API আছে যা একটি ব্যবহারকারীর ডাটা ফেরত দেয়। Postman দিয়ে একটি GET রিকোয়েস্ট পাঠানোর প্রক্রিয়া দেখানো হলো।

  1. URL এবং HTTP Method: প্রথমে Postman এ GET রিকোয়েস্ট নির্বাচন করুন এবং API URL ইনপুট করুন।

    https://jsonplaceholder.typicode.com/users

    এখানে jsonplaceholder হল একটি ফ্রি REST API যা ডেমো ডাটা প্রদান করে।

  2. Send Request: এখন Send বাটনে ক্লিক করুন।
  3. Response: Postman রেসপন্স হিসেবে API এর আউটপুট দেখাবে। যদি সঠিকভাবে কাজ করে, আপনি JSON ডাটা দেখতে পাবেন।

Step 4: POST Request Testing (API Post Data)

ধরা যাক, আপনি একটি নতুন ব্যবহারকারী ইনপুট করতে চান। Postman এ POST রিকোয়েস্ট পাঠানোর প্রক্রিয়া নিচে দেখানো হয়েছে।

  1. URL এবং HTTP Method: প্রথমে Postman এ POST রিকোয়েস্ট নির্বাচন করুন এবং API URL ইনপুট করুন:

    https://jsonplaceholder.typicode.com/users
  2. Body: এখানে আপনি Body ট্যাব নির্বাচন করে JSON ডাটা দিতে পারেন:

    {
        "name": "John Doe",
        "email": "john.doe@example.com"
    }
  3. Send Request: Send বাটনে ক্লিক করুন।
  4. Response: API রেসপন্স হিসেবে নতুন ব্যবহারকারীর ডাটা (JSON) ফেরত দেবে, যার মধ্যে একটি নতুন id থাকবে।

Step 5: PUT Request Testing (Update Data)

ধরা যাক, আপনি একটি ব্যবহারকারীর তথ্য আপডেট করতে চান। এখানে একটি PUT রিকোয়েস্টের উদাহরণ দেওয়া হলো:

  1. URL এবং HTTP Method: Postman এ PUT রিকোয়েস্ট নির্বাচন করুন এবং API URL ইনপুট করুন:

    https://jsonplaceholder.typicode.com/users/1
  2. Body: আপনার আপডেট করা ডাটা দিয়ে Body ফিল্ড পূর্ণ করুন:

    {
        "name": "Jane Doe",
        "email": "jane.doe@example.com"
    }
  3. Send Request: Send বাটনে ক্লিক করুন।
  4. Response: API রেসপন্স হিসেবে নতুন আপডেট হওয়া ডাটা ফেরত দিবে।

৩. Postman Collection এবং Environment ব্যবহার

Postman Collection

Postman এর Collection ফিচার ব্যবহার করে আপনি একাধিক API রিকোয়েস্ট সংরক্ষণ এবং গ্রুপ করতে পারেন। এটি আপনাকে একাধিক রিকোয়েস্ট একসাথে টেস্ট করতে সাহায্য করে।

  • আপনি Collection তৈরি করে বিভিন্ন API রিকোয়েস্ট সংরক্ষণ করতে পারেন এবং একযোগে বিভিন্ন API টেস্ট করতে পারেন।

Postman Environment

Postman এর Environment ফিচার ব্যবহার করে আপনি ডিফারেন্ট সেটিংস, যেমন base URL, API keys, authentication tokens ইত্যাদি সংরক্ষণ করতে পারেন। এটি আপনার টেস্টিংকে আরও সহজ এবং দ্রুত করে।


৪. Automated API Testing with Postman

Postman আপনাকে Automated Testing এর সুবিধা দেয় যেখানে আপনি Test Scripts লিখে স্বয়ংক্রিয়ভাবে API রেসপন্স যাচাই করতে পারেন। Postman এ Test scripts লিখতে আপনি JavaScript ব্যবহার করতে পারেন।

Example: Status Code Check (Test Script)

  1. Test Script ট্যাব নির্বাচন করুন।
  2. এখানে আপনি একটি টেস্ট স্ক্রিপ্ট লিখে API রেসপন্স যাচাই করতে পারেন:
pm.test("Status code is 200", function () {
    pm.response.to.have.status(200);
});

এটি নিশ্চিত করবে যে, API রেসপন্সের স্ট্যাটাস কোড 200 (OK) আছে।


৫. API Testing Best Practices

  1. Authentication and Authorization: JWT, OAuth বা অন্যান্য নিরাপত্তা প্রটোকল ব্যবহার করে API রিকোয়েস্টে অ্যাক্সেস কন্ট্রোল যাচাই করুন।
  2. Edge Cases: API টেস্টিং করার সময় Edge Cases এবং Error Handling পরীক্ষা করুন (যেমন, ভুল ইনপুট, অপ্রত্যাশিত রিকোয়েস্টস, ইত্যাদি)।
  3. Performance Testing: Load Testing এবং Stress Testing করে দেখুন API কতটা ট্রাফিক হ্যান্ডল করতে সক্ষম।
  4. Security Testing: SQL Injection, Cross-site Scripting (XSS), Cross-site Request Forgery (CSRF) ইত্যাদি নিরাপত্তা ঝুঁকি পরীক্ষা করুন।

সারাংশ

  • Postman একটি শক্তিশালী টুল যা API Testing, ডিবাগিং, এবং ডেভেলপমেন্টের জন্য ব্যবহৃত হয়।
  • Postman ব্যবহার করে আপনি GET, POST, PUT, এবং DELETE রিকোয়েস্ট পাঠাতে পারেন এবং তাদের রেসপন্স দেখতে পারেন।
  • Automated Testing এবং Test Scripts ব্যবহার করে API রেসপন্স স্বয়ংক্রিয়ভাবে যাচাই করা যায়।
  • Postman এর Collection এবং Environment ফিচারগুলি API টেস্টিংকে আরও সংগঠিত এবং সহজ করে তোলে।

এভাবে, Postman ব্যবহার করে API Testing এর কার্যক্রম দ্রুত এবং কার্যকরীভাবে করা সম্ভব।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...